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Important notice 
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The present document may be made available in more than one electronic version or in print. In any case of existing or 

perceived difference in contents between such versions, the reference version is the Portable Document Format (PDF). 

In case of dispute, the reference shall be the printing on ETSI printers of the PDF version kept on a specific network drive 

within ETSI Secretariat. 

Users of the present document should be aware that the document may be subject to revision or change of status. 

Information on the current status of this and other ETSI documents is available at 

http://portal.etsi.orq/tb/status/status.asp 

If you find errors in the present document, please send your comment to one of the following services: 

http://portal.etsi.orq/chaircor/ETSI support.asp 

Copyright Notification 

No part may be reproduced except as authorized by written permission. 
The copyright and the foregoing restriction extend to reproduction in all media. 

© European Telecommunications Standards Institute 2007. 
All rights reserved. 

DECT™, PLUGTESTS™and UMTS™ are Trade Marks of ETSI registered for the benefit of its Members. 
TIPHON™ and the TIPHON logo are Trade Marks currently being registered by ETSI for the benefit of its Members. 
3GPP™ is a Trade Mark of ETSI registered for the benefit of its Members and of the 3GPP Organizational Partners. 
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Intellectual Property Rights 



IPRs essential or potentially essential to the present document may have been declared to ETSI. The information 
pertaining to these essential IPRs, if any, is publicly available for ETSI members and non-members, and can be found 
in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in 
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web 
server ( http://webapp.etsi.org/IPR/home.asp) . 

Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee 
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web 
server) which are, or may be, or may become, essential to the present document. 



Foreword 

This Technical Specification (TS) has been produced by ETSI 3rd Generation Partnership Project (3GPP). 

The present document may refer to technical specifications or reports using their 3GPP identities, UMTS identities or 
GSM identities. These should be interpreted as being references to the corresponding ETSI deliverables. 

The cross reference between GSM, UMTS, 3 GPP and ETSI identities can be found under 
http://webapp.etsi.org/key/queryform. asp . 
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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3 GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



The present document contains an electronic copy of the ANSI-C code for the Floating-point Enhanced aacPlus codec 
[1]- 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 26.401: "Enhanced aacPlus general audio codec; General Description". 

[2] 3GPP TS 26.403: "Enhanced aacPlus general audio codec; Encoder Specification AAC part". 

[3] 3GPP TS 26.404: "Enhanced aacPlus general audio codec; Encoder Specification SBR part". 

[4] 3GPP TS 26.405: "Enhanced aacPlus general audio codec; Encoder Specification Parametric 

Stereo part" . 

[5] ISO/IEC 14496-3:2001 : "Information technology - Coding of audio-visual objects - Part 3: 

Audio". 

[6] ISO/IEC 14496-3:2001/Amd. 1:2003: "Bandwidth Extension". 

[7] ISO/IEC 14496-3:2001/Amd.l:2003/DCOR1". 

[8] ISO/IEC 14496-3:2001/ Amd.2:2004: "Parametric Coding for High Quality Audio. 

[9] 3GPP TS 26.402: Enhanced aacPlus general audio codec; Additional Decoder Tools". 

3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in TS 26.401 [1], TS 26.403 [2], TS 26.404 
[3], TS 26.405 [4] and TS 26.402 [9] apply. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

AAC Advanced Audio Coding 

aacPlus Combination of MPEG-4 AAC and MPEG-4 Bandwidth extension (SBR) 

Enhanced aacPlus Combination of MPEG-4 AAC, MPEG-4 Bandwidth extension (SBR) and MPEG-4 

Parametric Stereo 
MDCT Modified Discrete Cosine Transform 

QMF Quadrature Mirror Filter 

SBR Spectral Band Replication 
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ANSI 

GSM 

I/O 

RAM 

ROM 



American National Standards Institute 

Global System for Mobile communications 

Input/Output 

Random Access Memory 

Read Only Memory 



4 Floating point ANSI-C code structure 

This clause gives an overview of the structure of the floating point ANSI-C code and provides an overview of the 
contents and organization of the C code attached to the present document. 

The C code has been verified on the following systems: 

- IBM PC/AT compatible computers with Windows XP, 2000 and Microsoft Visual C++ v.6.0 compiler. 

IBM PC/AT compatible computers with Linux OS and GCC v. 3. 3 compiler. 

ANSI-C was selected as the programming language because portability was desirable. 

4.1 Contents of the floating point ANSI-C source code 

The C code distribution is organised in two directories for encoder and decoder and further into several subdirectories, 
reflecting the major building blocks of the Enhanced aacPlus codec. The file descriptions on root level as well as the 
directory structure is given as follows: 

Table 1 : Source code directory structure for the encoder (FloatFR_aacPlusenc) 



Directory 


Description 


README.txt 


information on how to compile 


Makefile 


UNIX style encoder Makefile 


FloatFR aacPlusEnc.dsw 


Win32 MSVC 6.0 encoder workspace 


FloatFR aacPlusEnc.dsp 


Win32 MSVC 6.0 encoder makefile 


src/ 


directory for the encoder frontend 


FloatFR fastaacenc/ 


AAC encoder library 


FloatFR resamplib/ 


resampler library 


FloatFR sbrenclib/ 


SBR encoder library 



Table 2: Source code directory structure for the decoder (FloatFR_aacPlusdec) 



Directory 


Description 


README.txt 


information on how to compile 


Makefile 


UNIX style encoder Makefile 


FloatFR_aacPlusdec_mp 
eg4.dsw 


Win32 MSVC 6.0 decoder workspace 


FloatFR_aacPlusdec_mp 
eg4.dsp 


Win32 MSVC 6.0 decodec makefile 


src/ 


directory for the decoder frontend 


FloatFR aacdec 


AAC decoder library 


FloatFR sbrdeclib/ 


SBR decoder library 



Table 3: Source code directory structure common for encoder and decoder 



Directory 


Description 


FloatFR bitbuflib/ 


bitstream reading/writing library 


FloatFRlib/ 


general purpose functionalities 


lib/ 


precompiled libraries for audio and bitstream 
file format handling 
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The distributed files with suffix "c" contain the source code and the files with suffix "h" are the header files. Within the 
respective libraries, the RAM data is contained in "xxx_ram" files with suffix "c", the ROM data is contained in 
"xxx_rom" files with suffix "c". Makefiles are provided for the platforms in which the C code has been verified (listed 
above). 

Note that the FloatFRlib/, FloatFR_bitbuflib/ and lib/ directory are identical for encoder and decoder. A list of source 
code files with the respective lines of code (pure C instructions) is given below: 

Table 4: Encoder source code files and lines of code 



Directory 


Module 


Lines of code 


src/ 


main.c 


332 




mp4file.c 


255 


FloatFR fastaacenclib/ 


qc_main.c 


224 




aacenc.c 


136 




ms stereo. c 


50 




spreading. c 


10 




interface.c 


44 




bit cnt.c 


588 




adj thr.c 


592 




quantize. c 


56 




psy configuration.c 


175 




sf estim.c 


508 




tns param.c 


45 




grp data.c 


114 




pre echo control. c 


22 




stprepro.c 


149 




tns.c 


358 




dyn bits.c 


281 




psy main.c 


232 




channel map.c 


52 




block switch. c 


201 




band nrg.c 


34 




transform.c 


151 




bitenc.c 


262 




line pe.c 


55 




Stat bits.c 


107 


FloatFR sbrenclib/ 


qmf enc.c 


565 




ton corr.c 


287 




fram gen.c 


688 




env bit.c 


56 




env est.c 


630 




mh det.c 


515 




hybrid. c 


139 




bit sbr.c 


375 




ps bitenc.c 


225 




sbr main.c 


355 




tran det.c 


183 




sbr misc.c 


49 




code env.c 


290 




nf est.c 


195 




freq_sca.c 


309 




invf est.c 


140 




ps enc.c 


299 


FloatFR_resamplib/ 


iir32resample.c 


71 




resampler.c 


68 



ETSI 



3GPP TS 26.410 version 7.2.0 Release 7 



ETSI TS 126 410 V7.2.0 (2007-10) 



Table 5: Decoder source code files and lines of code 



Directory 


Module 


Lines of code 


src/ 


main.c 


299 




fileifc.c 


173 




spline resampler.c 


172 


FloatFR aacdec/ 


aacdecoder.c 


172 




streaminfo.c 


10 




channelinfo.c 


102 




stereo. c 


78 




longblock.c 


234 




shortblock.c 


241 




pulsedata.c 


24 




block.c 


163 




pns.c 


89 




imdct.c 


50 




tns.c 


137 




bitstream.c 


15 




channel.c 


92 




conceal. c 


245 




dse.c 


9 


FloatFR sbrdeclib/ 


env dec.c 


370 




FFR aacPLUScheck.c 


32 




sbr bitb.c 


37 




env calc.c 


775 




Ipp tran.c 


504 




sbrdecoder.c 


514 




sbr dec.c 


218 




sbr crc.c 


45 




sbr fft.c 


615 




hybrid. c 


140 




ps bitdec.c 


223 




huff dec.c 


9 




env extr.c 


655 




freq_sca.c 


337 




ps dec.c 


317 




qmf dec.c 


526 



Table 6: Common source code files and lines of code 



Directory 


Module 


Lines of code 


FloatFR bitbuflib/ 


bitbuffer.c 


111 


FloatFRlib/ 


cfftn.c 


649 




transcendent.c 


15 



4.2 Program execution 



The Enhanced aacPlus codec is implemented in two programs: 
enhAacPlusEnc.exe 

- enhAacPlusDec.exe 

The programs should be called like: 

- enhAacPlusEnc.exe <wav_file> <bitstream_file> <bitrate> <(m)ono/(s)tereo> 

- enhAacPlusDec.exe <bitstream_file> <wav_file> <mode> [error_pattern_file] 

The audio files contain 16-bit linear encoded PCM samples with wav header, the bitstream files are of 3 GPP type an the 
error patter file is a ASCII file, see section 5. 

The encoder and decoder command line handling is also explained by running the applications without input arguments. 
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4.3 Memory requirements 



The data types of variables and tables used in the floating-point implementation are plain ANSI-C data types, the 
following types are used: 

- char 

- unsigned char 

- short 
-int 

- unsigned int 
-float 

4.3.1 Constants and tables 

This clause contains a listing of all constants and tables contributing to the ROM requirements of the encoder and 
decoder. 
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Table 7: Encoder constants and tables 



Name 


Data 
type 


Size 
[word] 


Allocated in 
Source File 


Description 


LongWindowSine 


float 


1024 


aac rom.c 


Window coefficients 


ShortWindowSine 


float 


128 


aac rom.c 


Window coefficients 


LongWindowKBD 


float 


1024 


aac rom.c 


Window coefficients 


fftTwiddleTab 


float 


513 


aac rom.c 


FFT twiddle coefficients 


quantTableQ 


float 


16 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


quantTableE 


float 


17 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


invQuantTableQ 


float 


16 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


invQuantTableE 


float 


17 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


pow4_3_tab 


float 


64 


aac_rom.c 


Quantizer table, used for efficient pow () 
implementation 


p 8000 mono long 


float 


4 


aac rom.c 


TNS tuning parameters 


p_8000_stereo_long 


float 


4 


aac rom.c 


TNS tuning parameters 


p 8000 mono short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 8000 stereo short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 16000 mono long 


float 


4 


aac rom.c 


TNS tuning parameters 


p 16000 stereo long 


float 


4 


aac rom.c 


TNS tuning parameters 


p_1 6000_mono_short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 16000 stereo short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 24000 mono long 


float 


4 


aac rom.c 


TNS tuning parameters 


p 24000 stereo long 


float 


4 


aac rom.c 


TNS tuning parameters 


p 24000 mono short 


float 


4 


aac rom.c 


TNS tuning parameters 


p_24000_stereo_short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 32000 mono long 


float 


4 


aac rom.c 


TNS tuning parameters 


p_32000_stereo_long 


float 


4 


aac rom.c 


TNS tuning parameters 


p 32000 mono short 


float 


4 


aac rom.c 


TNS tuning parameters 


p 32000 stereo short 


float 


4 


aac rom.c 


TNS tuning parameters 


tnsCoeff3 


float 


8 


aac rom.c 


TNS filter coefficients 


tnsCoeff3Borders 


float 


8 


aac rom.c 


TNS filter borders 


tnsCoeff4 


float 


16 


aac rom.c 


TNS filter coefficients 


tnsCoeff4Borders 


float 


16 


aac rom.c 


TNS filter borders 


tnslnfoTab 


int 


24 


aac rom.c 


TNS bitrate to tuning mapping table 


tnsMaxBandsTab 


int 


27 


aac rom.c 


max. TNS bands per sampling rate table 


huff Itabi 2 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff Itab3 4 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff Itab5 6 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff Itab7 8 


short 


64 


aac rom.c 


Huffman codeword table AAC 


huff Itab9 10 


short 


168 


aac rom.c 


Huffman codeword table AAC 


huff Itabi 1 


short 


288 


aac rom.c 


Huffman codeword table AAC 


huff Itabscf 


short 


120 


aac rom.c 


Huffman codeword table AAC 


huff ctabi 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab2 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab3 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab4 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab5 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab6 


short 


80 


aac rom.c 


Huffman codeword table AAC 


huff ctab7 


short 


64 


aac rom.c 


Huffman codeword table AAC 


huff ctab8 


short 


64 


aac rom.c 


Huffman codeword table AAC 


huff ctab9 


short 


168 


aac rom.c 


Huffman codeword table AAC 


huff ctabi 


short 


168 


aac rom.c 


Huffman codeword table AAC 


huff ctabi 1 


short 


288 


aac rom.c 


Huffman codeword table AAC 


huff ctabscf 


short 


242 


aac rom.c 


Huffman codeword table AAC 


sfb 11025 long 1024 


char 


43 


aac rom.c 


Scalefactor band table 


sfb 11025 short 128 


char 


15 


aac rom.c 


Scalefactor band table 


sfb 12000 long 1024 


char 


43 


aac rom.c 


Scalefactor band table 


sfb 12000 short 128 


char 


15 


aac rom.c 


Scalefactor band table 


sfb 16000 long 1024 


char 


43 


aac rom.c 


Scalefactor band table 


sfb 16000 short 128 


char 


15 


aac rom.c 


Scalefactor band table 


sfb 22050 long 1024 


char 


47 


aac rom.c 


Scalefactor band table 
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sfb 22050 short 128 


char 


15 


aac rom.c 


Scalefactor band table 


sfb 24000 long 1024 


char 


47 


aac rom.c 


Scalefactor band table 


sfb 24000 short 128 


char 


15 


aac rom.c 


Scalefactor band table 


panClass 


float 


7 


sbr rom.c 


Parametric Stereo quantization table 


saClass 


float 


7 


sbr rom.c 


Parametric Stereo quantization table 


p4 13 


float 


13 


sbr rom.c 


Hybrid filterbank coefficients 


p8 13 


float 


13 


sbr rom.c 


Hybrid filterbank coefficients 


sbr cos twiddle 


float 


16 


sbr rom.c 


QMF filterbank twiddle table 


sbr sin twiddle 


float 


16 


sbr rom.c 


QMF filterbank twiddle table 


sbr alt sin twiddle 


float 


17 


sbr rom.c 


QMF filterbank twiddle table 


sbr qmf 64 640 


float 


325 


sbr rom.c 


QMF window coefficients 


p_64_640_qmf 


float 


640 


sbr_rom.c 


QMF window coefficients (Note: could be made 
obsolete) 


trig Data fct4 32 


float 


32 


sbr rom.c 


FFT twiddle table 


trig Data fct4 16 


float 


16 


sbr rom.c 


FFT twiddle table 


trigData_fct4_8 


float 


8 


sbr rom.c 


FFT twiddle table 


aBookPslidTimeCode 


int 


29 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslidFreqCode 


int 


29 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aHybridResolution 


int 


3 


sbr rom.c 


Number of hybrid bands in each QMF band 


hiResBandBorders 


int 


21 


sbr rom.c 


Borders of Parametric Stereo bins 


groupBordersMix 


int 


29 


sbr rom.c 


Borders of Parametric Stereo groups 


bins2groupMap 


int 


29 


sbr_rom.c 


Mapping of Parametric Stereo bins to Parametric 
Stereo groups 


v_Huff_envelopeLevelC1 OT 


int 


121 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelCIOF 


int 


121 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCI OF 


int 


49 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCI OT 


int 


49 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelCIIT 


int 


63 


sbr rom.c 


Huffman codeword table SBR 


V Huff NoiseLevelCIIT 


int 


63 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceCI IT 


int 


25 


sbr rom.c 


Huffman codeword table SBR 


bookSbrNoiseBalanceCI IT 


int 


25 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelC1 1 F 


int 


63 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceC1 1 F 


int 


25 


sbr rom.c 


Huffman codeword table SBR 


aBookPslidTimeLength 


char 


29 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslidFreqLength 


char 


29 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccFreqLength 


char 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccTimeLength 


char 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


V Huff envelopeLevelLIOT 


char 


121 


sbr rom.c 


Huffman codeword table SBR 


v_Huff_envelope Level LI OF 


char 


121 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceLI OF 


char 


49 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceLI OT 


char 


49 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelLIIT 


char 


63 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceLI IT 


char 


25 


sbr rom.c 


Huffman codeword table SBR 


V Huff NoiseLevelLIIT 


char 


63 


sbr rom.c 


Huffman codeword table SBR 


bookSbrNoiseBalanceLI IT 


char 


25 


sbr rom.c 


Huffman codeword table SBR 


V Huff envelopeLevelLIIF 


char 


63 


sbr rom.c 


Huffman codeword table SBR 


bookSbrEnvBalanceL1 1 F 


char 


25 


sbr rom.c 


Huffman codeword table SBR 


aBookPslccFreqCode 


short 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


aBookPslccTimeCode; 


short 


15 


sbr rom.c 


Huffman codeword table Parametric Stereo 


logDualisTable 


float 


65 


transcendent.c 


Lookup table for efficient log() implementation 


setl a 


float 


14 


resampler.c 


MR filter coefficients for 2:1 resampling 


setl b 


float 


14 


resampler.c 


MR filter coefficients for 2:1 resampling 


setl 


float 


5 


resampler.c 


MR filter coefficients for 2:1 resampling 


coeffNum 


float 


8 


iir32resample.c 


MR filter coefficients for 3:2 resampling 


coeffDen 


float 


8 


iir32resample.c 


MR filter coefficients for 3:2 resampling 


tuningTable 


tuningT 
able 


231 


sbr_main.c 


SBR tuning parameters 


Sum 




8555 







Table 8: Decoder constants and tables 



Name 


Data 
type 


Size 
[word] 


Allocated in 
Source File 


Description 


tnsCoeff3 


float 


8 


aac rom.c 


TNS filter coefficients 
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tnsCoeff4 


float 


16 


aac rom.c 


TNS filter coefficients 


trigData 


float 


513 


aac rom.c 


Sine table, used for efficient sin(), cos() 


OnlyLongWindowKBD 


float 


1024 


aac rom.c 


Window coefficients 


OnlyShortWindowKBD 


float 


128 


aac rom.c 


Window coefficients 


OnlyLongWindowSine 


float 


1024 


aac rom.c 


Window coefficients 


OnlyShortWindowSine 


float 


128 


aac rom.c 


Window coefficients 


sfb 48 1024 


short 


50 


aac rom.c 


Scalefactor band table 


sfb 48 128 


short 


15 


aac rom.c 


Scalefactor band table 


sfb 32 1024 


short 


51 


aac rom.c 


Scalefactor band table 


sfb 24 1024 


short 


49 


aac rom.c 


Scalefactor band table 


sfb 24 128 


short 


16 


aac rom.c 


Scalefactor band table 


sfb 16 1024 


short 


44 


aac rom.c 


Scalefactor band table 


sfb 16 128 


short 


16 


aac rom.c 


Scalefactor band table 


sfb 8 1024 


short 


41 


aac rom.c 


Scalefactor band table 


sfb 8 128 


short 


16 


aac rom.c 


Scalefactor band table 


HuffmanCodeBook 1 


short 


204 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 2 


short 


156 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 3 


short 


156 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 4 


short 


152 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 5 


short 


164 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 6 


short 


160 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 7 


short 


124 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 8 


short 


124 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 9 


short 


336 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 10 


short 


328 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook 11 


short 


544 


aac rom.c 


Huffman codeword table AAC 


HuffmanCodeBook SCL 


short 


260 


aac rom.c 


Huffman codeword table AAC 


SamplingRatelnfoTable 


mixed 


45 


aac_rom.c 


Sampling rate to scalefactor mapping 
table AAC 


HuffmanCodeBooks 


mixed 


52 


aac rom.c 


Huffman codeword table AAC 


tns max bands tbi 


char 


18 


aac rom.c 


max. TNS bands per sampling rate table 


sbr limGains 


float 


4 


sbr rom.c 


SBR limitergain values 


sbr limiterBandsPerOctave 


float 


4 


sbr rom.c 


Number of SBR limiter bands 


sbr smoothFilter 


float 


4 


sbr rom.c 


Smoothing filter for gain values 


sbr invlntTable 


float 


55 


sbr rom.c 


Table of 1/x function 


sbr_randomPhase 


float 


1024 


sbr_rom.c 


Random numbers for SBR noise addition 
and PNS 


sbr qmf 64 640 


float 


325 


sbr rom.c 


QMP window coefficients 


sbr cos twiddle L04 


float 


2 


sbr rom.c 


PPT twiddle table 


sbr cos twiddle L08 


float 


4 


sbr rom.c 


PPT twiddle table 


sbr cos twiddle LI 6 


float 


8 


sbr rom.c 


PPT twiddle table 


sbr cos twiddle L32 


float 


16 


sbr rom.c 


PPT twiddle table 


sbr sin twiddle L04 


float 


2 


sbr rom.c 


PPT twiddle table 


sbr sin twiddle L08 


float 


4 


sbr rom.c 


PPT twiddle table 


sbr sin twiddle LI 6 


float 


8 


sbr rom.c 


PPT twiddle table 


sbr sin twiddle L32 


float 


16 


sbr rom.c 


PPT twiddle table 


sbr alt sin twiddle L04 


float 


3 


sbr rom.c 


PPT twiddle table 


sbr alt sin twiddle L08 


float 


5 


sbr rom.c 


PPT twiddle table 


sbr alt sin twiddle LI 6 


float 


9 


sbr rom.c 


PPT twiddle table 


sbr alt sin twiddle L32 


float 


17 


sbr rom.c 


PPT twiddle table 


sbr_cos_twiddle_ds_L32 


float 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_sin_twiddle_ds_L32 


float 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_cos_twiddle_L64 


float 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_sin_twiddle_L64 


float 


32 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr_alt_sin_twiddle_L64 


float 


33 


sbr_rom.c 


PPT twiddle table, obsolete for mono only 
decoder 


sbr t cos L32 


float 


32 


sbr rom.c 


PPT twiddle table 


sbr t sin L32 


float 


32 


sbr rom.c 


PPT twiddle table 


aRevLinkDecaySer 


float 


3 


sbr_rom.c 


Parametric Stereo all-pass filter 
coefficients 


aFractDelayPhaseFactorReQmf 


float 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 


aPractDelayPhasePactorlmQmf 


float 


20 


sbr rom.c 


Parametric Stereo phase rotation factor 
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aFractDelayPhaseFactorReSubQmf 


float 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aFractDelayPhaseFactorlmSubQmf 


float 


10 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerReQmf 


float 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerlmQmf 


float 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerReSubQmf 


float 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


aaFractDelayPhaseFactorSerlmSubQmf 


float 


3 


sbr rom.c 


Parametric Stereo phase rotation factor 


scaleFactors 


float 


15 


sbr rom.c 


Parametric Stereo quantization table 


scaleFactorsFine 


float 


41 


sbr rom.c 


Parametric Stereo quantization table 


alphas 


float 


8 


sbr rom.c 


Parametric Stereo quantization table 


p2 6 


float 


6 


sbr rom.c 


Hybrid filterbank coefficients 


p8 13 


float 


14 


sbr rom.c 


Hybrid filterbank coefficients 


sbr whFactorsTable 


float 


54 


sbr rom.c 


Tuning parameters for inverse filtering 


bins2groupMap 


short 


22 


sbr_rom.c 


Mapping of Parametric Stereo bins to 
Parametric Stereo groups 


sbr_whFactorslndex 


short 


9 


sbr_rom.c 


Tuning parameter index for inverse 
filtering 


sbr start freq 16 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 22 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr_start_freq_24 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 32 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr_start_freq_44 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr start freq 48 


char 


16 


sbr rom.c 


SBR frequency scale index 


sbr frame infol 16 


char 


18 


sbr rom.c 


SBR frequency scale index 


sbr frame info2 16 


char 


18 


sbr rom.c 


SBR frequency scale index 


sbr frame info4 16 


char 


18 


sbr rom.c 


SBR frequency scale index 


sbr huff Book EnvLevellOT 


char 


240 


sbr rom.c 


Huffman codeword table SBR 


sbr huff Book EnvLevellOF 


char 


240 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancelOT 


char 


96 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancelOF 


char 


96 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvLevelllT 


char 


124 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvLevelllF 


char 


124 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancellT 


char 


48 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook EnvBalancellF 


char 


48 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook NoiseLevelllT 


char 


124 


sbr rom.c 


Huffman codeword table SBR 


sbr huffBook NoiseBalancellT 


char 


48 


sbr rom.c 


Huffman codeword table SBR 


aRevLinkDelaySer 


char 


3 


sbr_rom.c 


Parametric Stereo all-pass delay line 
lengths 


groupBorders 


char 


23 


sbr rom.c 


Borders of Parametric Stereo groups 


aBookPslidTimeDecode 


char 


56 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFreqDecode 


char 


56 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslccTimeDecode 


char 


28 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslccFreqDecode 


char 


28 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFineTimeDecode 


char 


120 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


aBookPslidFineFreq Decode 


char 


120 


sbr_rom.c 


Huffman codeword table Parametric 
Stereo 


sbr defaultHeader 


char 


32 


sbr rom.c 


Default SBR header data 


logDualisTable 


float 


65 


transcendent.c 


Lookup table for efficient log() 
implementation 


Sum 




9866 
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4.3.2 Static memory 

This clause contains a listing of all static buffers contributing to the RAM requirements of the encoder and decoder. 

Table 9: Encoder static memory 



Name 


Data type 


Size 
[word] 


Allocated in 
Source File 


Description 


mdctDelayBuffer 


float 


3200 


aac ram.c 


Time domain input signal delay 


sidelnfoTabLong 


int 


52 


aac_ram.c 


Table lookup for side information, long 
blocks 


sidelnfoTabShort 


int 


16 


aac_ram.c 


Table lookup for side information, short 
blocks 


aacEncoder 


AAC ENCODER 


3554 


aacenc.c 


AAC encoder instance 


sbr QmfStatesAnalysis 


float 


1280 


sbr ram.c 


QMF filterbank states buffer 


sbr envYBuffer 


float 


4096 


sbr ram.c 


QMF band energy buffer 


sbr_quotaMatrix 


float 


512 


sbr ram.c 


Tonality values 


sbr thresholds 


float 


128 


sbr ram.c 


Detector parameters 


sbr toncorrBuff 


float 


1256 


sbr ram.c 


Detector value buffer 


EnvChannel[nChan] 


ENV_CHANNEL 


1794 


sbr_main.c 


SBR channel instance, only half the 
size for mono only encoder 


sbrEncoder 


SBR ENCODER 


200 


sbr main.c 


SBR encoder instance 


SynthesisQmfBank 


SBR QMF FILTE 
R BANK 


7 


sbr_main.c 


QMF synthesis filterbank instance 


psEncoder 


PS ENC 


281 


sbr main.c 


Parametric Stereo encoder instance 


sbrJreqBandTableLO 


char 


14 


sbr_ram.c 


SBR frequency band table, low 
resolution 


sbrJreqBandTableHI 


char 


28 


sbr_ram.c 


SBR frequency band table, high 
resolution 


sbr V k master 


char 


28 


sbr ram.c 


SBR frequency band table index 


sbr guideScfb 


char 


54 


sbr ram.c 


Additional sine detection parameter 


sbr detectionVectors 


char 


216 


sbr ram.c 


Additional sine detection parameter 


sbr_prevEnvelopeCompensa 
tion 


char 


54 


sbr_ram.c 


Additional sine detection parameter 


sbr guideVectorDetected 


char 


216 


sbr ram.c 


Additional sine detection parameter 


outputBuffer 


int 


384 


main.c 


Bitstream output buffer 


inputBuffer[nChan] 


float 


7202 


main.c 


Time domain input signal buffer, only 
half the size for mono only encoder 


IIR21_resampler[nChan] 


float 


144 


main.c 


2:1 MR resampler instance (includes 
states) , only half the size for mono only 
encoder 


statesllR 


float 


16 


iir32resample 
.c 


3:2 MR resampler states buffer 


Sum 




24732 
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Table 10: Decoder static memory 



Name 


Data type 


Size 
[word] 


Allocated in 
Source File 


Description 


OverlapBuffer[nChan] 


float 


1024 


aac_ram.c 


Delay buffer for overlap and add, 
only half the size for mono only 
decoder 


AacDecoderlnstance 


AAC DECODER INS 
TANCE 


11 


aacdecoder.c 


AAC decoder instance 


Streamlnfo 


CStreamlnfo 


7 


aac ram.c 


Bitstream information 


AacDecoderStaticChannellnfo[ 
nChan] 


CaacDecoderStaticCh 
annellnfo 


16 


aac_ram.c 


Channel information, only half the 
size for mono only decoder 


sbr CodecQmfStatesAnalysis 


float 


640 


sbr ram.c 


QMF analysis filter bank states 


sbr GainSmooth 


float 


96 


sbr ram.c 


Gain smoothing filter states 


sbr NoiseSmooth 


float 


96 


sbr ram.c 


Noise level smoothing filter states 


sbr QmfStatesSynthesis 


float 


1280 


sbr ram.c 


QMF synthesis filter bank states 


sbr_OverlapBuffer 


float 


1536 


sbr_ram.c 


SBR delay buffer, only half the 
size for mono only decoder 


sbr LpcFilterStatesReal 


float 


128 


sbr ram.c 


LPC filter states 


sbr_LpcFilterStateslmag 


float 


128 


sbr_ram.c 


LPC filter states, obsolete for 
mono only decoder 


sbr_TransposerSettings 


float 


18 


sbr_ram.c 


Transposer configuration 
parameters 


FreqBandData 


FREQ BAND DATA 


164 


sbr ram.c 


SBR Frequency band information 


PrevFrameData[nChan] 


SBR PREV FRAME 
DATA 


120 


sbr_ram.c 


SBR previous frame data, only 
half the size for mono only 
decoder 


sbr PrevBitstream 


SBRBITSTREAM 


146 


sbr ram.c 


SBR previous frame bitstream 


sbrDecoderlnstance 


SBR DECODER INS 
TANCE 


797 


sbrdecoder.c 


SBR decoder instance 


TimeDataFloat[nChan] 


float 


4096 


main.c 


Output buffer for time-domain 
signal, only half the size for mono 
only decoder 


inBuffer 


int 


384 


main.c 


Input buffer for bitstream 


splineResamplerlnstance 


SPLINE RESAMPLE 
R 


21 


spline_resam 
pler.c 


Spline resampler instance 


Sum 




10708 







4.3.3 Dynamic memory 

This clause contains a listing of all dynamic buffers contributing to the RAM requirements of the encoder and decoder. 
Dynamic memory can be re-used outside of the encoder or decoder application. 

Table 1 1 : Encoder dynamic memory 



Name 


Data 
type 


Size 
[word] 


Allocated in 
Source File 


Description 


PsBufS 


float 


1024 


sbr ram.c 


Note: reused in AAC encoder 


sbr envRBuffer 


float 


4096 


sbr ram.c 


Note: reused in AAC encoder 


sbr envlBuffer 


float 


4096 


sbr ram.c 


Note: reused in AAC encoder 


sbr transients 


float 


192 


sbr ram.c 


Note: reused in AAC encoder 


Sum 




9408 







Table 12: Decoder dynamic memory 



Name 


Data 
type 


Size 
[word] 


Allocated in 
Source File 


Description 


WorkBufferCore 


float 


2048 


aac ram.c 


Note: reused in SBR decoder 


InterimResult 


float 


1024 


sbr ram.c 




Sum 




3072 
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4.3.4 Maximum stack size 

This clause contains tables for the encoder and the decoder which describe the call stack that results in the maximum 
stack size usage. 

Table 13: Encoder call stack 



Function 


Local variables 


Stack 

used 

[bytes] 


main 


struct config; 

int error; 

int bEncodeMono; 

int bitrate; 

int nChannelsAAC, nChannelsSBR; 

int sampleRateAAC; 

int bandwidth; 

unsigned int numAncDataBytes; 

unsigned char ancDataBytes[256]; 

unsigned int ancDataLength; 

int numSamplesRead; 

int bDollR2Downsample; 

int bDingleRate; 

int useParametricStereo; 

int coreWriteOffset; 

int coreReadOffset; 

int envWriteOffset; 

int envReadOffset; 

int writeOffset; 

struct *aacEnc; 

int bDoUpsample; 

int upsampleReadOffset; 

int inSamples; 

int bDollR32Resample; 

int nSamplesPerChannel; 

const int nRuns; 

float *resamplerScratch; 

struct *hEnvEnc; 

int i, ch, outSamples, numOutBytes; 


20 
4 
4 
4 
8 
4 
4 
4 
256 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
16 
= 400 


EnvEncodeFrame 


struct *hEnvEncoder; 
float *samples; 
float *pCoreBuffer; 
unsigned inttimelnStride; 
unsigned int *numAncBytes; 
unsigned char *ancData; 
struct *sbrBitstreamData; 


4 
4 
4 
4 
4 
4 
4 
= 28 


extractSbrEnvelope 


float *timelnPtr; 

float *pCoreBuffer; 

unsigned inttimelnStride; 

struct *h_con; 

struct *sbrHeaderData; 

struct *sbrBitstreamData; 

struct *h_envChan[]; 

struct *h_ps_e; 

struct *hSynthesisQmfBank; 

struct *hCmonData; 

intch, i, j, c; 

int nEnvelopes[2]; 

inttransient_info[2][2]; 

const struct *frame_info[2]; 

int nChannels, nInChannels; 

enum stereoMode; 

enum res[10]; 

intv tuning[6]; 

intsfb_nrg[2][135]; 

float noiseFloor[2][10]; 


4 
4 
4 
4 
4 
4 
4 
4 
4 
4 

16 
8 

16 
8 
8 
4 

40 

24 
1080 

80 
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int noise_level[2][10]; 
int sfb_nrg_coupling[2][135]; 
int noise_level_coupling[2][10]; 
int maxQuantError; 


80 

1080 

80 

4 

= 2568 


EncodePsFrame 


struct *pms; 

float **iBufferLeft, 

float **rBufferLeft, 

float **iBufferRight, 

float **rBufferRight 

int env, i, bin, subband, maxSubband, startSample, stopSample; 

float **hybrLeftlmag, **hybrLeftReal, **hybrRightlmag, **hybrRightReal; 


4 

4 

4 

4 

4 

28 

16 

= 64 


HybridAnalysis 


const float **mQmfReal; 
const float **mQmflmag; 
float **mHybridReal; 
float **mHybridlmag; 
struct *hHybrid; 
int n, band; 
enum hybridRes; 
int chOffset; 


4 
4 
4 
4 
4 
8 
4 
4 
= 36 


eightChannelFiltering 


const float *pQmfReal; 
const float *pQmflmag; 
float **mHybridReal; 
float **mHybridlmag; 
int i, n; 

float real, imag; 
int midTap; 
floatcum[16]; 


4 
4 
4 
4 
8 
8 
4 
64 
= 100 


CFFTN 


float *afftData; 
int len; 
int isign; 


4 

4 

4 

= 12 


cfftn 


float Re[]; 

float lm[]; 

int nTotal; 

int nPass; 

int nSpan; 

int iSign; 

int ii, mfactor, kspan, ispan, inc, j, jc, jf, jj, k, k1 , k2, k3, k4, kk, kt, nn, ns, nt; 

double radf, c1 , c2, c3, cd, si , s2, s3, sd; 

float ak, bk, akp, bkp, ajp, bjp, ajm, bjm, akm, bkm, aj, bj, aa, bb; 

float Rtmp[23], ltmp[23]; 

double Cos[23], Sin[23]; 

int Perm[209]; 

int factor [11]; 

double s60, c72, s72, pi2; 


4 

4 

4 

4 

4 

4 

76 

72 

56 

184 

368 

836 

44 

32 

= 1692 




Sum 


4900 
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Table 14: Decoder call stack 



Function 


Local variables 


Stack 

used 

[bytes] 


mainQ 


int endOfFile; 

char frameOk; 

int i; 

int written16; 

charchannelMode; 

struct *hBitBuf; 

struct *aacDecoderlnfo; 

struct *streamSBR; 

struct *sbrDecoderlnfo; 

struct * splineResampler; 

intframeSize; 

int sampleRate, outputSampleRate; 

int numChannels; 

int numOutSamples; 

int bDownSample; 

int fosr16, fosr8; 

int bBitstreamDownMix; 

int bValidMode; 


4 
1 
4 
4 
1 
4 
4 
576 
4 
4 
4 
8 
4 
4 
4 
8 
4 
4 
= 646 


applySBRQ 


struct *self; 

struct *Bitstr; 

float *timeData; 

int *numChannels; 

int SbrFrameOK; 

int bDownSample; 

int bBitstreamDownMix; 

unsigned char i, dualMono; 

int stereo, CRCLen, crcEnable, readHeader, err; 

struct *SbrChannel; 

struct bitBuf; 

struct *hHeaderData; 

enum headerStatus; 

int codecFrameSize; 

enum initialSyncState; 

struct *hConcealData; 

float *pWorkBuffer1 ; 

struct *hFrameDataLeft; 

struct *hFrameDataRight; 


4 
4 
4 
4 
4 
4 
4 
2 
20 
4 
16 
4 
4 
4 
4 
4 
4 
4 
4 
= 102 


sbr_dec() 


struct *hSbrDec; 

float *timeln; 

float *timeOut; 

float *interimResult; 

struct *hHeaderData; 

struct *hFrameData; 

struct *hPrevFrameData; 

int applyProcessing; 

struct *h_ps_d; 

struct *hSynthesisQmfBankRight; 

int nChannels; 

int i, k, slot, ov len, bUseLP; 

float *QmfBufferReal[38]; 

float *QmfBufferlmag[38]; 

float *ptr; 

int noCols, halflen, islots; 


4 

4 

4 

4 

4 

4 

4 

4 

4 

4 

4 

20 

152 

152 

4 

12 

= 384 
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cplxSynthesisQmfFilteringQ 


float **qmf Real; 

float **qmflmag; 

float *timeout; 

struct *synQmf; 

int bUseLP; 

struct *h_ps_dec; 

int active; 

int i, j; 

float *ptr_time_out, *filterStates; 

float accu; 

intp; 

float qmfReal2[64]; 

float *imagSlot; 

int no_synthesis_channels; 

int qmf_filter_state_syn_size; 

float mfRealTmp[64]; 

float qmflmagTmp[64]; 

int env; 

const float *p_filter; 


4 
4 
4 
4 
4 
4 
4 
8 
8 
4 
4 
256 
4 
4 
4 
256 
256 
4 
4 
= 840 


ApplyPsSlotQ 


struct *h ps dec; 
float **rlntBufferLeft; 
float **ilntBufferLeft; 
float *rlntBufferRight; 
float *ilntBufferRight; 


4 
4 
4 
4 
4 
= 20 


HybridAnalysisQ 


const float **mQmfReal; 
const float **mQmflmag; 
float **mHybridReal; 
float **mHybridlmag; 
struct *hHybrid; 
int n, band; 
enum hybridRes; 
int chOffset; 


4 
4 
4 
4 
4 
8 
4 
4 
= 36 


eightChannelFilteringO 


const float *pQmf Real; 
const float *pQmflmag; 
float **mHybridReal; 
float **mHybridlmag; 
int i, n; 

float real, imag; 
int midTap; 
floatcum[16]; 


4 
4 
4 
4 
8 
8 
4 
64 
= 100 


CFFTNQ 


float *afftData; 
int len; 
int isign; 


4 

4 

4 

= 12 


cfftnO 


float Re[]; 

float lm[]; 

int nTotal; 

int nPass; 

int nSpan; 

int iSign; 

int ii, mfactor, kspan, ispan, inc, j, jc, jf, jj, k, k1 , k2, k3, k4, kk, kt, nn, 

ns, nt; 

double radf, c1 , c2, c3, cd, si , s2, s3, sd; 

float ak, bk, akp, bkp, ajp, bjp, ajm, bjm, akm, bkm, aj, bj, aa, bb; 

float Rtmp[23], ltmp[23]; 

double Cos[23], Sin[23]; 

int Perm[209]; 

int factor [11]; 

double s60, c72, s72, pi2; 


4 

4 

4 

4 

4 

4 

76 

72 

56 

184 

368 

836 

44 

32 

= 1692 




Sum 


3832 
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5 File formats 

This clause describes the file formats used by the encoder and decoder programs. 

5.1 Audio input file (encoder input/decoder output) 

The audio input files read by the encoder and written by the decoder are 16-bit PCM wave files. For convenient 
handling of wave files a precompiled audio-fileformat library is used. 

5.2 Bitstream file format (encoder output/decoder input) 

The encoder program writes and the decoder program reads raw frames packetized in access units as described by 3 GPP 
TS 26.244. For packetization the ISO media library is used. A precompiled library is used. 

5.3 Error pattern file (decoder input) 

The decoder program can optionally process an additional input file which describes an error pattern. The format of the 
error pattern file is 1 character per line. Each line corresponds to one frame, where a '0' indicates that the respective 
frame has been transmitted without errors, while a T indicates that the corresponding frame has been lost and error 
concealment shall be applied by the decoder. 
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Annex A (informative): 
Weighted MOPS and PROM 



The complexity numbers for the Enhanced aacPlus audio codec can be found in the following table, the numbers have 
been derived using the 'allcat.wav' item, which holds all the material from the selection test concatenated in one single 
item. For every test case the average and worst frame weighted MOPS figure has been derived. The worst case wMOPS 
figure over all test cases has been marked in blue. 

Table A.I : Weighted MOPS and PROM figures 





Test Case 


Mono Encoder 


Stereo Encoder 


Decoder 


Decoder, mono 
only 


wMOPS 

[average / 

worst frame] 


14m 


15.23/16.98 


15.36 / 17.21 


9.38/10.07 


8.07/8.78 


18s 


___ 


25.79/28.36 


19.48/20.35 


8.31 /9.17 


24m 


16.72/18.93 


16.86/19.14 


10.30/11.39 


8.89/9.94 


24s 


___ 


27.01/29.85 


20.45/21.63 


8.82/9.93 


32s 


___ 


27.49 / 29.97 


21.08/22.42 


9.28/10.58 


48s 


___ 


35.22 / 42.22 


17.96/20.26 


12.42/14.32 


14m, 16 kHz 


15.42/18.41 


15.47/18.46 


7.85/8.61 


7.85/8.60 


14m, 3%FER 


___ 


___ 


9.38/10.07 


8.07/8.78 


24s, 3% FER 


___ 


___ 


20.45/21.63 


8.81 /9.93 


32s, 1%FER 


___ 


___ 


21.08/22.42 


9.28/10.58 


32s, 3%FER 


___ 


___ 


21.08/22.38 


9.27/10.58 


Program ROM [ops] 


™ 


12540 


14365 


8048 


6209 
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Annex B (informative): 
Change history 



Change history 


Date 


TSG SA# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


2004-09 


25 


SP-040638 






Approved at SA#25 


2.0.0 


6.0.0 


2004-12 


26 


SP-040840 


001 




Correction to C-code to increase error robustness 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


002 




Correction to C-code: IVIissing memory re-initialization 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


003 




Correction to C-code: IVIemory initialization added 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


004 




Correction to C-code: Wrong calculation of sine levels 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


005 




Correction to C-code: Prevent multiple reading of 
bitstream elements 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


006 


2 


Correction to C-code: Corrected wrong table values 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


007 




Correction to C-code: Modify instrumentation 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


008 


1 


Correction of C-code: Output data was copied into wrong 
array 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


009 


1 


Correction to C-code: Bug in resampler 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


010 


1 


Correction to C-code: Modify data types for FFT 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


Oil 


1 


Correction to decoder C-Code: Alignment with MPEG 
specification 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


012 




Correction to C-code: Reset of Missing Harmonics flags 
during concealment added 


6.0.0 


6.1.0 


2004-12 


26 


SP-040840 


013 




Removal of Complexity counters 


6.0.0 


6.1.0 


2005-01 










File "env_calc.c" replaced in the attached ANSI-C code 


6.1.0 


6.1.1 


2005-03 


27 


SP-050095 


014 




Correction to C-code: 3GPP file format wrong writing of 
brand 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


015 




Correction to C-code: remove copyright notice from 
3GPP file format header files 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


016 




Correction to C-code: add capability for 10 kbit/s, mono 
encoding 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


017 




Correction to C-code: add capability for data stream 
element parsing 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


018 




Correction to C-code: PNS decoding algorithm not 
conform to MPEG 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


019 




Correction to C-code: the decoder mono only compile 
target not working correctly 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


020 




Correction to C-code: PS-decoding with varying upper 
frequency border not working correctly 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


021 




Correction to C-code: PS-decoding with variable framing 
not working correctly 


6.1.1 


6.2.0 


2005-03 


27 


SP-050095 


022 




Correction to written specification: move WMOPS 
numbers to informative Annex 


6.1.1 


6.2.0 


2005-06 


28 


SP-050251 


023 




Correction to C-code: 10 kbit/s mono encoding with 
stereo input files failed 


6.2.0 


6.3.0 


2005-09 


29 


SP-050426 


0024 




Correction to C-Code: Enable 44.1 kHz input material 
encoding (floating-point code) 


6.3.0 


6.4.0 


2005-09 


29 


SP-050426 


0025 




Correction of C-Code: removal of obsolete table (floating- 
point code) 


6.3.0 


6.4.0 


2005-12 


30 


SP-050786 


0027 




Correction to C-code: encoder bitrate switching 
simulation toolset 


6.4.0 


6.5.0 


2005-12 


30 


SP-050786 


0028 




Correction to C-code: encoder tuning table entry for 44.1 
kHz was wrong 


6.4.0 


6.5.0 


2005-12 


30 


SP-050786 


0029 




Correction to C-code: fix to make decoder more robust 
against corrupt input data 


6.4.0 


6.5.0 


2005-12 


30 


SP-050786 


0030 




Correction to C-code: removal of unused coefficients in 
resampler 


6.4.0 


6.5.0 


2006-03 


31 


SP-060013 


0031 




Correction to C-code: encoder switch is wrong 


6.5.0 


6.6.0 


2006-09 


33 


SP-060595 


0034 


1 


Correction of written specification: correct memory tables 
(floating-point code) 


6.6.0 


6.7.0 


2006-09 


33 


SP-060601 


0032 


2 


Modification of C-code: Change of encoder bitrate border 
for Parametric Stereo usage (floating-point code) 


6.7.0 


7.0.0 


2006-12 


34 


SP-060849 


0035 




Correction to C-code: Correct the maximum possible 


7.0.0 


7.1.0 
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SBR payload size (floating point code) 






2007-09 


37 


SP-070628 0038 


1 


Adding safety code to avoid encoder runtime-assertion 


7.1.0 


7.2.0 
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Document history 


V7.1.0 
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Publication 


V7.2.0 
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